from flask import current_app,flash
from app.exts import db,loginmanager
from werkzeug.security import generate_password_hash,check_password_hash
from itsdangerous import TimedJSONWebSignatureSerializer as Serializer
from flask_login import UserMixin
from .posts import Posts
#判断用户是否登录 以及 匿名用户   用户模型要继承与它
class Users(UserMixin,db.Model):
    __tablename__ = 'users'
    id = db.Column(db.Integer,primary_key=True,autoincrement=True)
    username = db.Column(db.String(20),unique=True)
    password_hash = db.Column(db.String(128))
    email = db.Column(db.String(64),unique=True)
    confirmed = db.Column(db.Boolean,default=False)
    icon = db.Column(db.String(64),default='default.jpg')

    #通过backref 反向访问 posts 的属性lazy 这里代表 不加载数据但是提供数据的查询
    posts = db.relationship('Posts',backref="user",lazy='dynamic')

    #添加收藏功能
    favorites = db.relationship('Posts',secondary='collections',backref=db.backref('useres',lazy='dynamic'),lazy='dynamic')

    #保护密码不被访问
    @property
    def password(self):
        raise AttributeError('密码你不可读')

    @password.setter
    def password(self,password):
        self.password_hash = generate_password_hash(password)

    # 密码校验方法
    def verify_password(self, password):
        return check_password_hash(self.password_hash,password)

    #生成token
    def generate_active_token(self,expires_in=3600):
        s = Serializer(current_app.config['SECRET_KEY'],expires_in=expires_in)
        return s.dumps({'id':self.id})

    #检测token
    @staticmethod
    def check_active_token(token):
        s = Serializer(current_app.config['SECRET_KEY'])
        try:
            data = s.loads(token)
        except:
            return False
        u = Users.query.get(data['id'])

        if not u:
            return False
        if not u.confirmed:
            u.confirmed = True
            db.session.add(u)
        return True
    #登录成功以后执行的回调函数
    @loginmanager.user_loader
    def load_user(uid):
        return Users.query.get(int(uid))

    #判断用户是否收藏了
    def is_favorite(self,pid):
        #先获取所有收藏的博客
        favorites = self.favorites.all()
        post = list(filter(lambda p:p.id == pid ,favorites))
        if len(post)>0 :
            return True
        return False
    #添加收藏功能
    def add_favorite(self,pid):
        p = Posts.query.get(pid) #先根据id 查询出来
        self.favorites.append(p) #然后追加到 第三张表中
    #取消收藏功能
    def del_favorite(self, pid):
        p = Posts.query.get(pid)  # 先根据id 查询出来
        self.favorites.remove(p)  #从第三张表中 移除



